- 
                Notifications
    You must be signed in to change notification settings 
- Fork 118
[core] Add user-facing API for Streaming Lambda functions that receive JSON events #532
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Pull Request Overview
Adds a new JSON-decoded streaming API for Swift AWS Lambda functions, including protocol definitions, adapters, tests, and documentation updates.
- Introduce StreamingLambdaHandlerWithEvent,StreamingLambdaCodableAdapter, and a closure-based handler to acceptDecodableinputs.
- Provide unit tests covering decoding, streaming, error handling, and background-work scenarios.
- Update root README, add a fully functional StreamingFromEvent example with SAM template, sample event, example code, and CI workflow updates.
Reviewed Changes
Copilot reviewed 10 out of 10 changed files in this pull request and generated no comments.
Show a summary per file
| File | Description | 
|---|---|
| readme.md | Added “Lambda Streaming Response with JSON Input” section | 
| Sources/AWSLambdaRuntime/LambdaStreaming+Codable.swift | New handler protocol, JSON adapter, and LambdaRuntimeinits | 
| Tests/AWSLambdaRuntimeTests/LambdaStreamingCodableTests.swift | Unit tests for streaming-codable handler and adapter | 
| Examples/StreamingFromEvent/template.yaml | SAM template for the new example | 
| Examples/StreamingFromEvent/events/sample-request.json | Sample JSON event for the example | 
| Examples/StreamingFromEvent/Sources/main.swift | Example usage of the JSON-streaming API | 
| Examples/StreamingFromEvent/README.md | Documentation for the new StreamingFromEvent example | 
| Examples/StreamingFromEvent/Package.swift | Package manifest for the example | 
| Examples/README.md | Added StreamingFromEvent to the examples index | 
| .github/workflows/pull_request.yml | Include StreamingFromEvent in CI example runs | 
Comments suppressed due to low confidence (5)
Examples/StreamingFromEvent/template.yaml:7
- The logical resource ID StreamingNumbersdoesn’t match the example folder name. Consider renaming it to something likeStreamingFromEventFunctionfor consistency.
  StreamingNumbers:
Examples/StreamingFromEvent/template.yaml:10
- The CodeUripath referencesStreamingNumbersbut should point to theStreamingFromEventbuild output (e.g..../StreamingFromEvent/StreamingFromEvent.zip).
      CodeUri: .build/plugins/AWSLambdaPackager/outputs/AWSLambdaPackager/StreamingNumbers/StreamingNumbers.zip
Examples/StreamingFromEvent/README.md:20
- There is no StreamingFromEventHandlerstruct in the example. Update this line to reference the actual closure-based handler or correct handler type used inmain.swift.
The sample code creates a `StreamingFromEventHandler` struct that conforms to the `StreamingLambdaHandlerWithEvent` protocol provided by the Swift AWS Lambda Runtime.
Tests/AWSLambdaRuntimeTests/LambdaStreamingCodableTests.swift:5
- The header uses 2024 but new code files use 2025. Update the copyright year to 2025 for consistency.
// Copyright (c) 2024 Apple Inc. and the SwiftAWSLambdaRuntime project authors
readme.md:305
- [nitpick] Consider renaming the link text to 'StreamingFromEvent example README file' to align with the directory name and avoid confusion.
You can learn how to deploy and invoke this function in [the streaming codable example README file](Examples/StreamingFromEvent/README.md).
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Some grammar/style changes
| ] | ||
| ) | ||
|  | ||
| if let localDepsPath = Context.environment["LAMBDA_USE_LOCAL_DEPS"], | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Something for a potential future PR - it would be good to simplify these example manifest and remove all of this in favour of a swift package edit in CI
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
OK, tracked here #536
However we should also consider development of the library itself and the examples. It's convenient to build with AS_LAMBDA_LOCAL_DEPS=../..
Co-authored-by: Tim Condon <[email protected]>
Co-authored-by: Tim Condon <[email protected]>
Co-authored-by: Tim Condon <[email protected]>
Co-authored-by: Tim Condon <[email protected]>
…lambda-runtime into sebsto/streaming+event
| @0xTim Thank you for your review and suggestions. All have been addressed | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM
… API (#549) Revert streaming codable handler change and propose it as an example instead of an handler API. **Motivation:** I made a mistake when submitting this PR #532 It provides a Streaming+Codable handler that conveniently allows developers to write handlers with `Codable` events for streaming functions. This is a mistake for three reasons: - This is the only handler that assumes a Lamba Event structure as input. I added a minimal `FunctionUrlRequest` and `FunctionURLResponse` to avoid importing the AWS Lambda Events library. It is the first handler to be event-specific. I don't think the runtime should introduce event specific code. - The handler only works when Lambda functions are exposed through Function URLs. Streaming functions can also be invoke by API or CLI. - The handler hides `FunctionURLRequest` details (HTTP headers, query parameters, etc.) from developers Developers were unaware they were trading flexibility for convenience The lack of clear documentation about these limitations led to incorrect usage patterns and frustrated developers who needed full request control or were using other invocation methods. **Modifications:** - Removed the Streaming+Codable API from the library - Moved the Streaming+Codable code to an example - Added prominent warning section in the example README explaining the limitations - Clarified when to use Streaming+Codable vs ByteBuffer approaches - Added decision rule framework to help developers choose the right approach **Result:** The only API provided by the library to use Streaming Lambda functions is exposing the raw `ByteBuffer` as input, there is no more `Codable` handler for Streaming functions available in the API. I kept the `Streaming+Codable` code an example. After this change, developers have clear guidance on when to use each streaming approach: - Use streaming codable for Function URL + JSON payload + no request details needed - Use ByteBuffer StreamingLambdaHandler for full control, other invocation methods, or request metadata access This prevents misuse of the API and sets proper expectations about the handler's capabilities and limitations, leading to better developer experience and fewer integration issues.
Add user-facing API for Streaming Lambda functions that receives JSON events
Motivation:
Streaming Lambda functions developed by developers had no choice but to implement a handler that receives incoming data as a
ByteBuffer. While this is useful for low-level development, I assume most developers will want to receive a JSON event to trigger their streaming Lambda function.Going efficiently from a
ByteBufferto a Swift struct requires some code implemented in theJSON+ByteBuffer.swiftfile of the librray. We propose to further help developers by providing them with a newhandler()function that directly receives theirDecodabletype.Modifications:
This PR adds a public facing API (+ unit test + updated README) allowing developers to write a handler method accepting any
Decodablestruct as input.This interface provides:
Because streaming Lambda functions can be invoked either directly through the API or through Lambda Function URL, this PR adds the decoding logic to support both types, shielding developers from working with Function URL requests and base64 encoding.
We understand these choice will have an impact on the raw performance for event handling. Those advanced users that want to get the maximum might use the existing
handler(_ event: ByteBuffer, writer: LambaStreamingWriter)function to implement their own custom decoding logic.This PR provides a balance between ease of use for 80% of the users vs ultimate performance, without closing the door for the 20% who need it.
Result:
Lambda function developers can now use arbitrary
DecodableSwift struct or Lambda events to trigger their streaming functions. 🎉